<!-- 定义模版对象 -->
<template>
  <div class="login_container">
    <div class="login_box">
      <!-- 头像区域-->
      <div class="avatar_box">
        <img src="../assets/logo.jpg" alt="VUE图片" />
      </div>

      <!-- 登陆表单区域 ref代表当前表单引用对象-->
      <el-form :model="loginForm" :rules="rules" ref="loginFormRef" label-width="0" class="login_form">
        <el-form-item prop="username">
          <el-input prefix-icon="iconfont iconuser" v-model="loginForm.username"></el-input>
        </el-form-item>
        <el-form-item prop="password">
          <el-input prefix-icon="iconfont iconsuo" type="password" v-model="loginForm.password"></el-input>
        </el-form-item>
        <el-form-item class="btns">
          <el-button type="primary" @click="login()">登录</el-button>
          <el-button type="info" @click="resetBtn()">重置</el-button>
        </el-form-item>
      </el-form>
    </div>
  </div>
</template>

<!-- 定义JS变量 -->
<script>
  export default {
    data() {
      return {
        // 如果是form表单提交 一般都会采用对象封装
        loginForm: {
          username: '',
          password: ''
        },
        // 表单校验，通过 rules 属性传入约定的验证规则，并将 Form-Item 的 prop 属性设置为需校验的字段名
        rules: {
          username: [{
              required: true,
              message: '请输入用户名',
              trigger: 'blur'
            },
            {
              min: 3,
              max: 5,
              message: '长度在 3 到 8 个字符',
              trigger: 'blur'
            }
          ],
          password: [{
              required: true,
              message: '请输入密码',
              trigger: 'blur'
            },
            {
              min: 6,
              max: 30,
              message: '长度在 6 到 30 个字符',
              trigger: 'blur'
            }
          ]
        }
      }
    },
    methods: {
      resetBtn() {
        // 获取当前的表单对象,并调用resetFields方法，重置数据
        this.$refs.loginFormRef.resetFields()
      },
      login() {
        // 要在登录前校验数据是否填写完成
        this.$refs.loginFormRef.validate(async valid => {
          // 如果没有校验成功，则直接结束调用
          if (!valid) return
          // 发起Ajax请求
          const {
            data: result
          } = await this.$http.post('/user/login', this.loginForm)
          // 1.判断状态码是否为200 用户名和密码是否错误
          if (result.status === 201)
            return this.$message.error('用户名或密码错误！')

          if (result.status === 500)
            return this.$message.error('服务器异常')

          // 如果登录成功，应该提示
          this.$message.success('用户登录成功！')
          // 将用户登录信息保存到sessionStorage
          let token = result.data
          window.sessionStorage.setItem('token',token)
          // 应该将页面重定向到home页面
          this.$router.push('/home')
        })
      }
    }

  }
</script>

<!-- 防止组件冲突 -->
<style lang="less" scoped>
  .login_container {
    background-color: #2b4b6b;
    height: 100%;
  }

  .login_box {
    width: 450px;
    height: 300px;
    background-color: #FFFFFF;
    /* 设定圆弧角*/
    border-radius: 10px;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);

    .avatar_box {
      height: 130px;
      width: 130px;
      border: 1px solid #EEEEEE;
      border-radius: 50%;
      padding: 10px;
      box-shadow: 0 0 10px #DDDDDD;
      /* 添加阴影*/
      position: absolute;
      /* 绝对定位*/
      left: 50%;
      /* 距离左侧50%*/
      transform: translate(-50%, -50%);
      /*回调50%*/
      background-color: #FFFFFF;

      img {
        height: 100%;
        width: 100%;
        border-radius: 50%;
        background-color: #EEEEEE;
      }
    }

    .btns {
      display: flex;
      justify-content: flex-end;

    }

    .login_form {
      position: absolute;
      bottom: 0;
      width: 100%;
      padding: 0 20px;
      box-sizing: border-box;
    }
  }
</style>
